草庐IT

pointers - 解析指针

全部标签

pointers - 不同类型的指针之间有什么区别?

指针指向内存中的一个位置。据我所知,实际上所有内存地址都具有相同的类型,与变量类型无关。除了使用不同的指针类型(*int、*string等),是否可以只使用一种类型(varppointer)所有指针类型?不同的指针类型有什么区别?packagemainimport"fmt"funcmain(){i:=5s:="abc"varpi*int//alternativelyvarpipointervarps*string//alternativelyvarpspointerpi=&ips=&sfmt.Printf("%p%p",pi,ps)//resultis0x1040e0f80x1040a

pointers - 在 Go 中增加一个指针

这个问题在这里已经有了答案:PointerarithmeticinGo(2个答案)关闭6年前。谁能告诉我如何在Go中通过字符串递增指针?我已经像在C中那样尝试了ptr+=1但它说类型*string和int是不兼容的。谢谢

go - 如何在golang中解析json中的 slice ?

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。关闭5年前。编辑问题以包含desiredbehavior,aspecificproblemorerror,andtheshortestcodenecessarytoreproducetheproblem.这将有助于其他人回答问题。这个问题是由于打字错误或无法再重现的问题引起的。虽然类似的问题可能是on-topic在这里,这个问题的解决方式不太可能帮助future的读者。Improvethisquestion我正在尝试解码json数据。里面的slice故意没有引号,因为这是我从https得到的(手动添加

go - 如何将字符串作为参数传递给 Golang 指针接收函数?

这个问题在这里已经有了答案:"usedasvalue"infunctioncall(1个回答)关闭4年前。我正在尝试一种带有值和指针接收函数的简单Go结构。我无法将一个字符串作为参数传递给指针接收函数来修改结构数据。任何人都可以帮忙吗?代码:packagemainimport("fmt")typebookstruct{authorstringnamestringcategorystringpriceint16}func(bbook)greet()string{return"Welcome"+b.author}func(b*book)changeAuthor(authorstring){

pointers - 无法通过结构方法替换指针

得到一个返回指针的结构方法:func(d*DataMap)Get(pCoord)*CellData{return&d.Data[p.X+(p.Y*d.Size)]}d.Data是一个CellData数组,它是一个具有多个字段的结构。使用这种方法我可以修改每个字段的内部值,即:example.Get(p).Something=123但是我不能这样做:example.Get(p)=*yada(yadaisa*CellData)我想用我得到的另一个指针替换指针的地方:cannotassigntoexample.Get(p)(undefined)我做错了什么?函数的输出已定义,不知道为什么会出

go - 我可以使用指向 "error"的指针来捕获返回错误吗?

我正在编写一些事务开始/提交/回滚函数,我想将block配对以防止忘记提交我是这样写的:func(foo*Foo)Bar()(errerror){foo.Begin()deferfoo.End(&err)//somebusinesscodereturn}func(foo*Foo)End(eptr*error){//ifrecoverifr:=recover();r!=nil{debug.PrintStack()*eptr=r.(error)}varerr=*eptriferr!=nil{foo.Rollback()}else{foo.Commit()}}它有效,但它使用“接口(inte

pointers - golang 中的指针

这个问题在这里已经有了答案:Whydoesjson.Unmarshalworkwithreferencebutnotpointer?(4个答案)关闭4年前。我正在使用golang来解析一个json字符串:str:="{...}"varfinterface{}json.Unmarshal([]byte(str),f)fmt.Println(f)虽然我在控制台中得到了nil。当我将代码更改为:json.Unmarshal([]byte(str),&f)它将打印json字符串。这是怎么回事?

当 bitSize 参数使用 32 时,Golang strconv.ParseFloat 无法正确解析字符串

为什么转换后的float64变量的值为1.590000033378601?1.59似乎小到可以放入32位:packagemainimport("fmt""strconv")funcmain(){str:=`1.59`float,err:=strconv.ParseFloat(str,32)iferr!=nil{fmt.Println("err:",err)}fmt.Printf("%T->%+v\n",float,float)}Goplaygroundlink 最佳答案 是32位变量的精度问题。这不是Go的问题。请参阅以下网址。IE

go - 为什么 go build 会因为 regexp.MustCompile 解析错误而成功?

gorun或gotest(编译然后运行)失败,但gobuild(仅编译)失败。我本以为MustCompile与编译有关,而不是运行时。packagemainimport("regexp")varsomeInvalidRegex=regexp.MustCompile(`(?!`)funcmain(){someInvalidRegex.MatchString("foo")}运行时失败:$gorunmain.gopanic:regexp:Compile(`(?!`):errorparsingregexp:invalidorunsupportedPerlsyntax:`(?!`goroutin

go - 无法在没有解析错误的情况下在 Google go 中添加时间

作品:{{$temp:=timestampToDate$var.date}}{{$temp.Format2006/01/02}}没用{{$temp:=timestampToDate$var.date}}{{$temp:=$temp.AddDate(0,-1,0)}}{{$temp.Format2006/01/02}}它说它无法用第二行解析文件,但问题是什么?据我所知,我正确地使用了命令。 最佳答案 乍一看问题似乎是由于在一个已经存在的变量上使用了:=语法,但这不是问题,正如这个例子所示:t:=template.Must(templa